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Cs301- current midterm paper-l(NOV 2011) 


Q:1 What is complete binary tree? 

Answer: 

"A complete binary tree is a binary tree with the additional property that every node must have exactly two 
children if an internal node, and zero children if a leaf node." 

Q:2 How single left rotation is performed in AVL tree? 

Answer: 

This rotation is almost similar to the single right rotation. We start from tree node kl. kl is the root whilet ree 
node k2 is its right child. Due to the left rotation, the right child k2 of the root kl will become the root. The kl 
will go down to the left child of k2. 

Q:3 describe the following 

(i) Height of tree 

(ii) Balance of Node 

(i) Height of tree 
Answer: (Page 209) 

The height of a binary tree is the maximum level of its leaves (also called the depth). 

(ii) Balance of Node 
Answer: (page 215) 

The balance of a node in a binary search tree is defined as the height of its left subtree minus height of its right 
subtree. In other words, at a particular node, the difference in heights of its left and right subtree gives the 
balance of the node. 


Cs301- current midterm paper-2(NOV 2011) 


Q1 what is binary tree brief it? 

Answer: - 

“A binary tree is a finite set of elements that is either empty or is partitioned into three disjoint subsets. The first 
subset contains a single element called the root of the tree. The other two subsets are themselves binary trees 
called the left and right sub-trees”. 

Q2.what is different between binary tree and AVL tree 
Answer:- (Page 212) 

An AVL tree is identical to a BST, barring the following possible differences: 

❖ Height of the left and right subtrees may differ by at most 1. 

❖ Height of an empty tree is defined to be (-1). 

Why queue is linear data structure. 

Answer:-(Page 87) 

A queue is a linear data structure into which items can only be inserted at one end and removed from the other. 

2 

Subscribe to Academia Coaches on Youtube 
https://www.youtube.com/channel/UCQ-hVBjZtF1 acgqHW HhhgQ 





In contrast to the stack, which is a LIFO (Last In First Out) structure, a queue is a FIFO (First In First Out) 
structure. 

How we can delete a node with two Childs in a binary search tree using its right sub tree. 

Answer:- Page 263 

The node to be deleted has either left child (subtree) or right child (subtree).In this case we bypass the node in 
such a way that we find the inorder successor of this node and then link the parent of the node to be deleted to 
this successor node. Thus the node was deleted. 

define const keyword, reference variable, Dangling reference 
Answer: (Page 198) 

Const keyword 

The const keyword is used for something to be constant. The actual meanings depend on where it occurs but it 
generally means something is to held constant. There can be constant functions, constant variables or parameters 
etc. 

Reference variable 

The references are pointers internally, actually they are constant pointers. You cannot perform any kind of 
arithmetic manipulation with references that you normally do with pointers. 

Dangling reference 

The pointer of the object (when object has already been deallocated or released) is called dangling pointer. 

Cs301- current midterm paper-3(NOV 2011) 

Q: 1 what is complete binary tree? 

Answer: (Page 123) 

The definition of the complete binary tree is 

A complete binary tree of depth d is the strictly binary tree all of whose leaves are level d. 

Q: 2 how single left rotation is performed in AVL tree? 

Answer: rep 

Q:3 describe the following 

(i) Height of tree 

(ii) Balance of Node 
Answer: rep 

Cs301- current midterm paper-4(NOV 2011) 

Q1 what is binary tree breif it? 

Answer:- rep 

Q2.what is different between binary tree and AVL tree 
Answer: rep 

Why queue is linear data structure. 

Answer: rep 
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MIDTERM EXAMINATION 2011 (MAY) 


1. What is function of length () method in the Queue 
Answer: (page 111) 

In Queue length() method, has a single statement i.e. 
return size ; 

This method returns the size of the queue, reflecting the number of elements in the queue. It is not the size of 
the array used internally to store the elements of the queue. 

2. Explain the two cases in which we apply double rotation in An Avl tree 
Answer: (Page 229) 

Sometimes a single rotation is not sufficient to balance an unbalanced tree. 

The two cases are following: 

1. Insertion into the right subtree of the left child of X node (RL) 

2. Insertion into the left subtree of the right child of X node (LR) 


3. How can we perform level-order traversal on a tree? 

Answer:- (For More detail and code see Page 161) 

We can print a binary tree level by level by employing recursive or non-recursive method. 

The idea of a level-order traversal is to visit the root, then visit all nodes "1 level away" (depth 2) from the root 
(left to right), then all nodes "2 levels away" (depth 3) from the root, etc. For the example tree, the goal is to 
visit the nodes in the following order: 


A B 
root 1 level 


D 


J 


G 


H 


J 


-y ~Y~ 

2 levels 3 levels 

away away away 

A level-order traversal requires using a queue (rather than a recursive algorithm, which implicitly uses a stack). 
A queue is a FIFO structure, which can make the level-order traversal easier. 


4. How can the dangling reference problem be avoided? 

Answer:- ( Page 200 ) 

To avoid dangling reference, don’t return the reference of a local variable (transient) from a function. 


MIDTERM EXAMINATION 2011 (MAY) 

Q:1 What is complete binary tree? 

Answer: rep 

Q:2 How single left rotation is performed in AVL tree? 

Answer: rep 

What is binary tree breif it? 

Answer:- rep 
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Why queue is linear data structure. 

Answer:- rep 

Q: Define const keyword, reference variable , Dangling reference 
Answer: rep 

Q:3 Describe the following 
(i) Height of tree 
Answer: rep 

Q.21A: - Similarity between AVL and Binary Search Tree? 

Answer:- rep 

Q.21B: - How AVL is different from Binary Search Tree? 

Answer:- (http://answers.yahoo.com/question/index?qid=20071213000314AAU8p08) 

A binary tree is a tree data structure in which each node has at most two children. Typically the child nodes are 
called left and right. One common use of binary trees is binary search trees; another is binary heaps. 

While an AVL tree is a self-balancing binary search tree. 

In an AVL tree the heights of the two child sub-trees of any node differ by at most one, therefore it is also called 
height-balanced. Lookup, insertion, and deletion all take 0(log n) time in both the average and worst cases. 
Additions and deletions may require the tree to be rebalanced by one or more tree rotations. 

Q.22: - What the maximum no of comparisons we have to perform during insertion in BST? 

Answer:- ( Page 139 ) 

If we have a complete binary tree with n numbers of nodes, the depth d of the tree can be found by the following 
equation: 

d=log 2 (n + 1) - 1 

If the tree is complete binary or near-to-complete, we need log 2 (n) number of comparison. Whereas in a 
linked list, the comparisons required could be a maximum of n. 


MIDTERM EXAMINATION 2010 


Question No: 19 (Marks: 2) 

What is Function Call Stack Give short answer? 

Answer:- 

Stacks play a key role in implementation of function calls in programming languages. 

In C++, for example, the “call stack” is used to pass function arguments and receive return values. 
The call stack is also used for “local variables” 
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Question No: 21 (Marks: 3) 

Here is a small binary tree. 



Write the order of the nodes visited in 

a) A Post-order traversal :(L, R, N) 

b) A level-order traversal 

Answer: - 

Post-order traversal:: CDBHFIGEA 
level-order traversal:: ABEDGCFIH 


MIDTERM EXAMINATION 2010 


Question No: 18 (Marks: 2 ) 

What are the applications of Binary Tree? 

Answer: - 

The binary tree is a useful data structure for rapidly storing sorted data and rapidly retrieving stored data. 

It can hold objects that are sorted by their keys. 

It can represent a structured object, An operating system maintains a disk's file system as a tree, where file 
folders act as tree nodes: 

MIDTERM EXAMINATION 2010 

Question No: 17 (Marks: 1) 

Give the names of basic Queue Operations 
Answer:- (page 88) 

Queue Operations 

The queue data structure supports the following operations: 

Operation Description 

enqueue(X) Place X at the rear of the queue. 
dequeue() Remove the front element and return it. 

front() Return front element without removing it. 

isEmpty!) Return TRUE if queue is empty, FALSE otherwise 
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Question No: 18 (Marks: 1) 

Give one benefit of using Stack. 

Answer:- (Page 53) 

In computer science, a stack is a last in, first out (LIFO) abstract data type and data structure. A stack can have 
any abstract data type as an element, but is characterized by only two fundamental operations: push and pop.the 
data structure itself enforces the proper order of calls. 


Question No: 21 (Marks: 5 ) 

Give short answers of the following questions: 

1. Why List wastes less memory as compared to Arrays. 

Answer: - 

1. Linked lists do not need contiguous blocks of memory; extremely large data sets stored in an array might not 
be able to fit in memory. 

2. Linked list storage does not need to be preallocated (again, due to arrays needing contiguous memory 
blocks). 

3. Inserting or removing an element into a linked list requires one data update, inserting or removing an 
element into an array requires n (all elements after the modified index need to be shifted). 

Array is a collection of same data type. In linked list there are two field one is address and other is pointer. In 
array elements are arranged in a specific order 

2. Why we can change the size of list after its creation when we can not do that in simple arrays? 
Answer:- 

Some how the answer will be same as part 1 because Inserting or removing an element into a linked list 
requires one data update, inserting or removing an element into an array requires n (all elements after the 
modified index need to be shifted). 

Array is a collection of same data type. The size of array is mentioned with its declaration, in arrays the 
elements are in contiguous position. One must after another. While in linked list we gave the address of next 
element in the next part of node. 

MIDTERM EXAMINATION 2010 


Question No: 19 (Marks: 2) 

Describe any two uses of priority queues? 

Answer:- (page 101) 

Priority queue being used at many places especially in the operating systems. In operating systems, we have queue of 
different processes. If some process comes with higher priority, it will be processed first. Here we have seen a 
variation of queue. We will use the priority queue in the simulation. The events will be inserted in the queue and the 
event going to occur first in future, will be popped. 
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Question No: 21 
Describe the Use of Queues? 

Answer:- (Page 96) 

Use of Queues: 

Out of the numerous uses of the queues, one of the most useful is simulation. A simulation program attempts to 
model a real-world phenomenon. Many popular video games are simulations, e.g., SimCity, Flight Simulator etc. 
Each object and action in the simulation has a counterpart in the real world. Computer simulation is very powerful 
tool and it is used in different high tech industries, especially in engineering projects. For example, it is used in aero 
plane manufacturing. Actually Computer Simulation is full-fledged subject of Computer Science and contains 
very complex Mathematics, sometimes. For example, simulation of computer networks, traffic networks etc. 

Question No: 22 (Marks: 3 ) 

How we evaluate postfix expressions? 

Answer: (Page 67) 

Evaluating Postfix Expression: 

o Each operator in a postfix expression refers to the previous two operands, 
o Each time we read an operand, we push it on a stack. 

o When we reach an operator, we pop the two operands from the top of the stack, apply the operator and 
push the result back on the stack. 


MIDTERM EXAMINATION 2010 

Question No: 18 (Marks: 1) 

What is meant by an empty stack? 

Answer: (Page 54) 

Empty stack means that there is no element on the stack. IsEmptyO boolean function returns true if stack is 
empty, false otherwise. 

Question No: 19 (Marks: 2 ) 

Is the following statement correct? If your answer is No, then correct it. 

“A tree is an AVL tree if at least half of the nodes fulfill the AVL condition” 

Answer: (page 214) 

Statement is wrong, Correct statement is: 

A tree is an AVL tree if all the nodes fulfill the AVL condition. 


MIDTERM EXAMINATION 2010 

Question No: 17 (Marks: 2) 

Which process places data at the back of the queue? 

Answer: (page 87) 

“ enqueue(X) “ Place X at the rear/back of the queue. 
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Question No: 18 (Marks: 2) 

How we can delete a node with two Childs in a binary search tree using its right sub tree. 

Answer:- (Page 263) 

The node to be deleted has either left child (sub-tree) or right child (sub-tree).In this case we bypass the node in 
such a way that we find the in-order successor of this node and then link the parent of the node to be deleted to 
this successor node. Thus the node was deleted. 

Question No: 19 (Marks: 2 ) 

Why we use Reference Variables. Give one example. 

Answer:- Click here for detail 

C++ references allow you to create a second name for the a variable that you can use to read or modify the 
original data stored in that variable. 

#include 
main() 

{ 

int x; 

int& foo = x; 

// foo is now a reference to x so this sets x to 56 
foo = 56; 

std::cout« x «std::endl; 

} 

17. Define Reference Variable, Dangling Reference & Const 

Answer:- 

In the C++ programming language, a reference is a simple reference datatype that is less 
than the pointer type inherited from C. The name C++ reference may cause confusion, as 
a reference is a general concept datatype, with pointers andC++ references being specific 
implementations Dangling Reference & Const 
Dangling pointers and wild pointers in computer encoding are pointers that do not point to a valid object of 
the suitable type. These are special cases of violations of memory safety 

18. What is the use of Reference Variable, Give example? 3 Marks 

Answer:- 

A reference variable is used to refer a particular object Location which resides on a garbage collectable heap. 
C++ supports one more type of variable called reference variable. In addition to pointer variable and value 
variable of reference variable behaves similar to both vaule variable and pointer variable. Reference variable 
has all access that variable has. 

Question No: 18 (Marks: 2) 

How we can avoid the problem of Dangling reference 
Answer:- 

To avoid dangling reference, don’t return the reference of a local variable (Transient) from a function. 


powerful but safer 
in computer science 
reference datatype 
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